草庐IT

mysql - 缩短嵌套 SQL 查询

全部标签

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

ruby-on-rails - Rails,如何避免 "N + 1"查询关联中的总数(计数、大小、counter_cache)?

我有这些模型:classChildren我现在需要的是在“电影院”的页面中,我想为那个电影院的电影打印children的总和(数量,大小?),所以我这样写:在cinemas_controller.rb中:@childrens=@cinema.childrens.uniq在cinemas/show.html.erb:但显然我有bulletgem提醒我Counter_cache并且我不知道把这个counter_cache放在哪里因为电影的不同id。而且在没有counter_cache的情况下,我所拥有的也不是我想要的,因为我想要计算该电影院中有多少child从该电影院许多天的门票中拿走了他

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

ruby - 从嵌套类调用父模块方法

我无法弄清楚如何从类中的父模块调用方法。我想在我的嵌套类中从父模块调用模块函数,但似乎无法找到执行此操作的方法。例子:moduleAwesomeclassCheckerdefawesome?awesome_detectionendendmodule_functiondefawesome_detectiontrueendend如果我调用Awesome::Checker.new.awesome?,它不知道awesome_detection关于我遗漏的任何想法? 最佳答案 #!/usr/bin/envruby-wKUmoduleAweso

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby - YAML 中的多层嵌套

我正在尝试使用YAML创建应用程序中使用的所有存储过程的列表以及调用它们的位置。我设想了类似下面的内容,但我认为YAML不允许多层嵌套。access_log:stored_proc:getsomethinguses:usedin:some->bread->crumbusedin:somethingelseherestored_proc:anotherspuses:usedin:blahblahreporting:stored_proc:reportingspuses:usedin:breadcrumb有没有办法在YAML中做到这一点,如果没有,还有哪些其他选择?

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby - RSpec 找不到嵌套的格式化程序

我正在尝试仅针对Ruby(而非Rails)运行rspec,针对一个简单的Ruby文件。我正在关注Tut+TDDTestingwithRuby。我有一个competition目录,其中包含一个lib文件夹和一个spec文件夹。├──lib│  ├──competition.rb│  └──team.rb└──spec└──competition_spec.rb当我运行rspec时,我得到了这个错误。我可以发誓rspec以前工作过。我不知道发生了什么事。competition:>rspecspec/Users/akh88/.rvm/gems/ruby-1.9.3-p547/gems/rsp

ruby-on-rails - gem install mysql2 v '0.3.11' 无法在 Yosemite 上运行

在ruby​​版本1.9.3(rvm)上执行mysql2版本0.3.11的捆绑安装或直接gem安装时,我收到以下错误。但是当我安装最新版本0.3.16时它可以工作。我还包含了我的gcc版本以供引用。Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./Users/ginocarlocortez/.rvm/rubies/ruby-1.9.3-p547/bin/rubyextconf.rbcheckingforrb_thread_blocking_region()...yescheckingforrb_wait_for_si

ruby-on-rails - 无法在 Windows 7 上安装 MySQL2 gem

我在安装时收到以下错误消息,如果我需要发布更多详细信息,请告诉我。我按照以下位置的说明操作:https://github.com/oneclick/rubyinstaller/wiki/Development-Kit我正在使用ruby​​1.9.2p136(2010-12-25)[i386-mingw32]。这是我得到的:E:\work_desk\trunk>geminstallmysql2-v0.2.4TemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...ERR